<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>文章列表</title>
    <link rel="stylesheet" href="./libs/bootstrap/css/bootstrap.min.css">
    <link rel="stylesheet" href="./css/reset.css">
    <link rel="stylesheet" href="./css/iconfont.css">
    <link rel="stylesheet" href="./css/main.css">
    <script src="./libs/jquery-1.12.4.min.js"></script>
    <!-- 引入模板引擎js文件 -->
    <script src="./libs/template-web.js"></script>
    <!-- 导入加载文章分页插件 -->
    <script src="./libs/jquery.twbsPagination.js"></script>
</head>

<body>
    <div class="container-fluid">
        <div class="common_title">
            文章列表
        </div>
        <div class="container-fluid common_con">
            <div class="row opt_btns">
                <div class="col-xs-6">
                    <form class="form-inline">
                        <select id="selCategory" name="" class="form-control input-sm">
                            <option value="">所有分类</option>
                            <option>未分类</option>
                            <option>奇趣事</option>
                            <option>会生活</option>
                            <option>爱旅行</option>
                        </select>
                        <select id="selStatus" name="" class="form-control input-sm">
                            <option value="">所有状态</option>
                            <option value="草稿">草稿</option>
                            <option value="已发布">已发布</option>
                        </select>
                        <button id="btnSearch" class="btn btn-default btn-sm">筛选</button>
                    </form>
                </div>
                <div class="col-xs-6">
                    <a href="article_release.html" class="btn btn-success btn-sm pull-right" id="release_btn">发表文章</a>
                </div>
            </div>
            <table class="table table-striped table-bordered table-hover mp20">
                <thead>
                    <tr>
                        <th>标题</th>
                        <th>作者</th>
                        <th>分类</th>
                        <th class="text-center">发表时间</th>
                        <th class="text-center">状态</th>
                        <th class="text-center" width="100">操作</th>
                    </tr>
                </thead>
                <tbody>
                    <tr>
                        <td>王积千造统最头</td>
                        <td>杰克</td>
                        <td>奇趣事</td>
                        <td class="text-center">2017-06-08 07:08:46</td>
                        <td class="text-center">已发布</td>
                        <td class="text-center">
                            <a href="article_edit.html" class="btn btn-default btn-xs">编辑</a>
                            <button class="btn btn-danger btn-xs delete">删除</button>
                        </td>
                    </tr>
                </tbody>
            </table>
            <div class="row text-center">
                <ul id="pagination" class="pagination-sm"></ul>
            </div>
        </div>
    </div>
</body>

</html>
<!-- 生成模板引擎结构 -->
<script type="text/html" id="tpl-Category">
    <option value="">所有分类</option>
{{each}}
<option value="{{$value.id}}">{{$value.name}}</option>
{{/each}}
</script>
<!-- 生成文章类别模板引擎 -->
<script type="text/html" id="tpl-article">
{{each}}
<tr>
    <td>{{$value.title}}</td>
    <td>{{$value.author}}</td>
    <td>{{$value.category}}</td>
    <td class="text-center">{{$value.date}}</td>
    <td class="text-center">{{$value.state}}</td>
    <td class="text-center">
        <a dataid="{{$value.id}}" href="article_edit.html?dataid={{$value.id}}" class="btn btn-default btn-xs">编辑</a>
        <button dataid="{{$value.id}}" class="btn btn-danger btn-xs delete">删除</button>
    </td>
</tr>
{{/each}}
</script>

<script src="./libs/https.js"></script>
<script>
    $(function () {
        //发起Ajax请求,获取分类数据,渲染到select标签上
        // $.ajax({
        //     type: 'get',
        //     url: BigNew.category_list,
        //     success: function (backData) {
        //         let data = backData.data;
        //         $('#selCategory').html(template('tpl-Category', data))
        //     }
        // })
        // let seldata = 1
        // //获取后台数据,渲染到页面上, 次方法需要调用多次,所以封装成一个函数
        // function loadData(pages) {
        //     $.ajax({
        //         type: 'get',
        //         url: BigNew.article_query,
        //         data: {
        //             key: '',
        //             type: $('#selCategory').val(),
        //             state: $('#selStatus').val(),
        //             page: pages,
        //             perpage: 5,
        //         },
        //         success: function (backData) {
        //             if (backData.code == 200) {
        //                 if (backData.data.totalPage > 0) {
        //                     console.log(backData);
        //                     let data = backData.data.data;
        //                     //将模板结构渲染到页面上
        //                     $('tbody').html(template('tpl-article', data));
        //                     //调用分页插件之前先销毁之前的事件
        //                     $('#pagination').twbsPagination('destroy')
        //                     // 调用分页插件
        //                     $('#pagination').twbsPagination({
        //                         totalPages: backData.data.totalPage,
        //                         visiblePages: 10,
        //                         startPage: pages,
        //                         initiateStartPageClick: false,
        //                         // 设置按钮的文本:
        //                         first: '首页',
        //                         last: '尾页',
        //                         next: '下一页',
        //                         prev: '上一页',
        //                         onPageClick: function (e, page) {
        //                             seldata = page;
        //                             loadData(seldata)
        //                         }
        //                     })
        //                 } else {
        //                     $('tbody').html('');
        //                     $('#pagination').html('当前分页暂无数据,敬请期待!!');
        //                 }


        //             }
        //         }
        //     })
        // }
        // loadData(1);
        // //点击筛选按钮,显示出对应的分类数据
        // $('#btnSearch').on('click', function (e) {
        //     e.preventDefault();
        //     loadData(1)
        // })

        // // 给删除按钮委托设置点击事件
        // $('tbody').on('click', '.delete', function (e) {
        //     let dataid = $(this).attr('dataid');
        //     console.log(dataid);
        //     //发起ajax请求
        //     $.ajax({
        //         type: 'post',
        //         url: BigNew.article_delete,
        //         data: {
        //             id: dataid
        //         },
        //         success: function (backData) {
        //             if (backData.code == 204) {
        //                 if ($('tbody tr').length > 1 || seldata == 1) {
        //                     loadData(seldata)
        //                 } else {
        //                     loadData(--seldata)
        //                 }
        //             }
        //         }
        //     })
        // })











        //发起Ajax请求,将文章类别渲染到option列表中
        $.ajax({
            type: 'get',
            url: BigNew.category_list,
            success: function (backData) {
                if (backData.code == 200) {
                    let data = backData.data;
                    //调用模板引擎方法
                    let inHTML = template('tpl-Category', data);
                    //生成页面结构
                    $('#selCategory').html(inHTML);
                }
            }
        })

        let selpage = 1
        //封装一个函数,获取文章数据
        //page是点击时所在的分页页数
        function loadData(page) {
            //发起Ajax请求
            $.ajax({
                type: 'get',
                url: BigNew.article_query,
                data: {
                    type: $('#selCategory').val(),
                    state: $('#selStatus').val(),
                    page: page,
                    perpage: 5
                },
                success: function (backData) {
                    //如果输入内容大于0条
                    if (backData.data.totalCount > 0) {
                        if (backData.code==200) {
                            //获取后台返回的数据
                            let data = backData.data.data;
                            //调用模板引擎
                            let inHTML = template('tpl-article', data);
                            //将结构渲染到指定结构
                            $('tbody').html(inHTML)
                            //调用文章分页方法
                            //每一次调用此方法时,先摧毁原来的方法
                            $('#pagination').twbsPagination('destroy');
                            $('#pagination').twbsPagination({
                                //控制总页数
                                totalPages: backData.data.totalPage,
                                //控制显示的页数
                                visiblePages: 10,
                                // 控制被选中的页码
                                startPage: page,
                                // 关闭默认的初始化点击事件, 避免后面的递归
                                initiateStartPageClick: false,
                                // 设置按钮的文本:
                                first: '首页',
                                last: '尾页',
                                next: '下一页',
                                prev: '上一页',
                                // 当点击按钮的时候会执行以下函数
                                onPageClick: function (e, page) {
                                    //保存当前的页码
                                    selpage = page
                                    //调用loaddata方法,传入page参数
                                    loadData(page)
                                }
                            })
                        }
                    } else {
                        //清空tbody里面的内容
                        $('tbody').html('');
                        $('#pagination').html('当前分类没有任何数据,敬请期待!!')
                    }


                }
            })
        }
        //实参1为加载是默认加载的页数
        loadData(1);

        //给筛选按钮设置点击事件
        $('#btnSearch').on('click', function (e) {
            // 阻止默认刷新
            e.preventDefault();
            //刷新数据
            loadData(1)
        })

        //给所有删除按钮委托点击事件
        $('tbody').on('click', '.delete', function (e) {
            //获取当前点击按钮的id
            let id = $(this).attr('dataid');
            //发起Ajax请求
            $.ajax({
                type: 'post',
                url: BigNew.article_delete,
                data: {
                    id
                },
                success: function (backData) {
                    if (backData.code == 204) {
                        if ($('tbody tr').length > 1 || selpage == 1) {
                            loadData(selpage)
                        } else {
                            //当删除的是最后一页最后一条时,跳转到上一页
                            loadData(--selpage)
                        }
                    }
                }
            })
        })

    })
</script>